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Method of switching video sequences and corresponding switching device and decoding system. 



The present invention relates to a method of switching from a first video 
sequence to a second one, both old and new sequences being composed of pictures of type T = I, 
P or B according to the fact that said pictures are independently coded, or predicted from earlier I 
or P pictures, or bidirectionally predicted from earlier and later P pictures and/or I pictures. It also 
relates to a device for implementing said switching method and to a decoding system including 
such a device. This invention may be used for example for replacing a national television 
programme by a local one, and is particularly useful in relation with the MPEG-2 standard. 

The principles of said standard, adopted by the Moving Pictures Experts 
Group (MPEG) of the International Standard Organization (ISO) and described in numerous 
documents, are recalled in detailed manner for instance in "Switching facilities in MPEG-2 : 
necessary but not sufficient", SMPTE Journal, Vol. 104, n°12, December 1995, pp.788-802. 

As explained in that document, switching means the splicing of programme 
segments or complete programmes (including video, audio and related data), i.e in fact the 
concatenation of different elementary streams. In the following, for sake of simplicity, the 
description will be limited to the case of only two different bitstreams, that may have been 
generated at different locations and/or at different times, and were not a priori intended to be 
spliced together when they were generated. 

Concerning the structure itself of these bitstreams, it must be recalled that a 
compressed video sequence consists of groups of pictures (GOPs) comprising different types of 
coded pictures I, P and B. The I pictures Qntra coded) are independently coded (by intra-frame 
techniques only, with no need for previous information, i.e without reference to other pictures), 
while the P pictures (predictive-coded) are predicted from earlier I pictures or from earlier P ones, 
and the B pictures (bidirectionally predictive coded) are bidirectionally predicted from earlier and 
later P pictures and/or I pictures. 

According to these different types of prediction, pictures are coded with 
more or less efficiency (I pictures are the least efficiently coded ones, P pictures^are more 
efficient, and B pictures are the most efficient in their coding). Since the number of bits necessary 
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to code the pictures is not constant, as the decoding is done at a regular period T(V), the bits of 
the coded pictures do not spend the same time in the decoder's buffer. 



Buffer Verifier (VB V) and used to verify that an MPEG bitstream is decodable with reasonable 
buffering and delay requirement : by way of the buffer occupancy, constraints are imposed to the 
bitstream, so that decoding may occur without buffer underflow or overflow. The so-called 
vbv_delay then represents the time spent in said decoder's buffer by the first bit of a coded 
picture. Performing a switch with a picture regularly decoded at said period T(V) is not possible if 
the vbv_delays of the first "old" picture suppressed and the first "new" picture transmitted are 
different (one calls the old pictures the ones which will be replaced by the new ones from a given 
point : this point, called the splice, is the boundary between data belonging to the old bitstream 
and data belonging to the new one). Moreover, since the sizes of the pictures replaced and the 
pictures inserted are different, a decoder's buffer underflow or overflow may occur. A simple 
switch between two coded video sequences is therefore generally not possible. 

In order to avoid any presentation discontinuity at the display side (no 
apparent interruption in the flow of the data keeps the viewers absorbed on a continuous basis), it 
is necessary to have no decoding discontinuity, which is possible only if the splice is seamless, i.e. 
if a smoothly flowing bitstream is obtained. This implies that the decoding time of the first access 
unit of the new stream is consistent with respect to the decoding time of the access unit of the old 
stream preceding the splice, which is generally not the case except at favourable locations that are 
called splicing points and are indicated in particular fields of the bitstreams. Such an access point 
is located between two coded pictures and defines a fixed standardized vbv_delay value of the 
first bit following such a point, also called splice decoding delay (the construction of a splicing 
point also guarantees that no overflow is generated at the transition between old and new 
sequences). A switching operation can then be performed only if the same splicing points are 
present on both new and old video sequences. However, currently these points are purely formal, 
only few splice decoding delay values are defined, and no coding systems are able to perform 
them. Moreover, in case of video sequence replacement (i.e. of two successive video switchings, 
with a first forward transition from the old sequence to the new one, and a second backward 
transition from the new sequence back to the old one), splicing points can be used only if the 
temporal position of the old and new splicing points corresponding to the backward switching are 
predictable and compatible. This implies regular and standard GOP structure for the two video 
sequences, but this requirement is generally not fulfilled. 



The MPEG standard specifies an abstract model of decoding called Video 
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A first object of the invention is therefore to propose a method that allows 

video sequence switching without the constraints of splicing point creation. 

To this end the invention relates to a method such as described in the 

preamble of the description and moreover characterized in that an additional sequence of k 

5 pictures is inserted at the switching point between the two sequences, k having a value sufficient 

in order to have compatible sequences and said additional pictures being coded with a few number 

ofbits. 

According to said method, the new video sequence is delayed by k periods 
T(V) until vbv_delays are compatible. This delay creates for the decoder a lack of k pictures 

10 between the old and the new video sequence, and the additional sequence of k pictures takes this 
place. The decoder will now continuously and successfully display the pictures of the old 
sequence, the k minimal pictures, and the pictures of the new sequence. 

[ f; Another object of the invention is to propose a device for implementing said 

Q switching method. 

r |j5 To this end the invention relates, in a decoding system for decoding n parallel 

H video bitstreams corresponding to video sequences of pictures said intra if they have been coded 
M 5 without any reference to any other picture or said predicted or interpolated according to the fact 



that they are predicted by motion-compensated prediction from an earlier intra or predicted 
picture or bidirectionally interpolated from an earlier and a later picture, or in association with 



O 

m 

1/20 such a system, to a switching device comprising selecting means provided for a selective 

switchover of the bitstream which has to be decoded according to a switching method such as 
hereinabove described. 



Another object of the invention is also to propose a decoding system 
including such a switching device. 

25 To this end the invention relates to a decoding system for decoding n parallel 

video bitstreams corresponding to video sequences of pictures said intra if they have been coded 
without any reference to any other picture or said predicted or interpolated according to the fact 
that they are predicted by motion-compensated prediction from an earlier intra or predicted 
picture or bidirectionally interpolated from an earlier and a later picture, said system comprising a 

30 switching device that includes in cascade selecting means, for the selection of the bitstream which 
has to be decoded, and decoding means for decoding said selected bitstream, wherein said 
selecting means comprise, in view of the implementation of a method as hereinabove described, 
control means for a selective switchover of the bitstream which has to be decoded. 



) 



4 



08.05.1998 



The particularities and advantages of the invention will now become more 
apparent from the following description and the accompanying drawings, in which : 

- Figs.l and 2 are graphs of decoder's buffer fullness versus time respectively 
without the invention and when the invention is implemented ; 

- Fig. 3 illustrates a possible problem of buffer overflow, and Fig.4 the solution 
proposed according to the invention ; 

- Fig. 5 is a flowchart illustrating the successive steps of the switching method 
according to the invention ; 

- Fig. 6 shows an embodiment of a decoding system including a switching device 
according to the invention. 

In order to better understand the principles of the invention, some problems 
occurring when switching must be recalled. A first switching problem is illustrated in Fig.l, which 
is a graph of decoder's buffer fullness DBF versus time. The first line R(OLD) corresponds to the 
bitstream associated to the first replaced picture of the old sequence and designates the video 
bitrate of the old sequence, that has to be replaced by the new one. This last picture, without 
switching (i.e. if not replaced), is decoded at time TD(0). If switching occurs, the first transmitted 
picture of the new sequence (the line R(NEW) corresponds to the bitstream associated to this first 
transmitted picture, R(NEW) designating the video bitrate of this new sequence) would be 
decoded at the same time TD(0). As the local video bitrate R(NEW) is lower than the national 
one R(OLD), and considering therefore the VB V_delays VB V(OLD) and VB V(NEW) associated 
to each picture respectively and the corresponding times TS(OLD) and TS(NEW) (with : 
TS(OLD) = the time when the first bit of the first replaced picture of the old sequence enters the 
decoder's buffer = TD(OLD) - VBV(OLD) ; TS(NEW) = the time when the first bit of the first 
transmitted picture of the new sequence enters (theoritically) the decoder's buffer = 
TD(NEW) - VBV(NEW) ; TD(OLD) and TD(NEW) = times when said first replaced picture and 
first transmitted picture are decoded), it appears in fact that TS(NEW) occurs before TS(OLD) 
and that it is therefore impossible to send at the same time the bits of the last transmitted picture 
of the old sequence and the bits of the first transmitted picture of the new one. 



manner), it has therefore been decided to insert at the forward transition (when switching from the 
old sequence to the new one) an additional sequence of k pictures, delaying the new sequence by 
k periods T(V). The number k is sufficient to allow TS(NEW) to occur after TS(OLD), and said 



According to the invention (see Fig. 2, explained later in a more detailed 
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k pictures have particular characteristics that allow them to be easily coded (they are represented 

by a few number of bits and are therefore called minimal pictures in the description). 

The aim of the minimal pictures is, while the new sequence is delayed, to 

empty the decoder's buffer as soon as possible. A way to constitute such an additional sequence is 

5 for instance to consider a sequence of k uniform colour pictures (called UC pictures in the 

following) where all the pixels are identical (for instance an I picture and (k-l).P pictures). 

Another solution is to consider a sequence of k P pictures, obtained for example by considering 

the pictures of said minimal sequence as copies of a previous I or P picture, which is equivalent, 

for the decoder, to freeze the last I or P picture of the old sequence during (k.T(V)) seconds. 

10 In the case of k UC pictures, since all pictures are the same, the P pictures 

can be described, in the compression syntax, as copies of the first I picture with a minimum 
number of bits. Thus the additional processing step required to code said UC sequence is 

jf; restricted to the encoding of the first I picture of this sequence. 

Q In the case of k P pictures, these pictures are described by the MPEG-2 

syntax as the copy of the previous one. In fact the effect of such a technical solution on the 
transition is the freeze of the last picture of the old sequence during k.T(V) seconds instead of 



U! 

J* having UC pictures during the same period. 



In both cases, due to VBV_delay considerations, a minimum number of 
minimal pictures has to be inserted at the considered transition (as can be seen in Fig.l). In view 

tfiO of the determination of said number in case of UC pictures, the following notations (in bits) are 

15 

\\l chosen : 

D(I) = size of the I pictures of the UC picture sequence ; 
D(P) = size of the P pictures of the UC picture sequence ; 
S(MAX) = size of the decoder's buffer. 
25 The minimum number k depends on the characteristics of the first replaced picture of the old 
sequence and those of the first inserted picture of the new one. Knowing that the pictures are 
decoded at the constant period T(V), the number k has to be such that, between TS(OLD) and 
TS(NEW), all the bits of the k UC pictures are transmitted. This is possible if : 
TS(NEW) - TS(OLD) > (D(I) + (k-l).D(P))/R(OLD) (1), 
30 that is to say if TS(NEW) - TS(OLD) is greater than the duration of the period that is needed for 
the transmission of the minimal pictures at the bitrate R(OLD). This condition leads for k to a 
minimal value given by the relation (2) : 
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(J ov ^ w ; WDy ^ > R (OLD) J t(R(OLD).T(V))-D(P)J W 
Since VBV(NEW) is over-bounded by S(MAX)/R(NEW), k can be approximately over-bounded 
by k(MAX) such as : 

k(MAX)>f S < MAX > V l (3) 
V ' 1^R(NEW).T(V)J 

5 In view of the determination of the minimum number in case of k P pictures, 

the relation (2) is now replaced by the following relation (4) : 

k>(VBV(^W)-VBV(OLD))( ^ (oL g^> — ) (4) 

The proposed solution is illustrated in Fig. 2, which is the modified graph of 
decoder's buffer fullness DBF versus time when said solution is implemented : TS(NEW) now 

W occurs after TS(OLD), the last transmitted picture of the old sequence may be, considering the 

P 

H value of VBV(OLD), decoded at TD(-l), the first transmitted picture of the new sequence may 

vp be, considering the value of VBV(NEW), decoded at TD(2), and, between these first replaced 

W and first transmitted pictures, minimal pictures are sent between TS(OLD) and TS(NEW) and 

M- decoded at TD(0) and TD(1). 

Moreover, since the transmitted rates R(OLD) and R(NEW) are generally 
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. u different, when a switching transition occurs, the input rate entering the decoder's buffer is 
ifl different from the one that would have entered without any switching, and there is a risk of 
iy overflow in the buffer when the input rate becomes greater. A verification of non overflow must 
consequently be carried out. Decoder's buffer fullness must be computed from time TS(NEW) to 
20 time TD(OLD). If an overflow is possible, minimal pictures must be inserted until the condition of 
non overflow is verified or until TS(NEW) is higher than TD(OLD). The number k of minimal 
pictures verifying this last condition is such as : TD(OLD)-TS(NEW) < 0, which leads to : 
k > (VBV(NEW)/T(V)) + 1. Since VBV(NEW) is over-bounded by S(MAX)/R(NEW), k can be 

over-bounded by k(MAX) such as : k(MAX) > [ R( ^^ ( v) j 

25 which is identical to the previous result (relation (3)). 

This problem of possible buffer overflow when R(NEW) is greater than 
R(OLD) can be seen in Fig.3, illustrating the evolution of the decoder's buffer fullness S(t) 
(S(MAX) designates the maximum value of S(t)). The line L(OS) corresponds to the state, at 
each time t, of the buffer fullness for the old sequence alone : at times TD(-7), TD(-6),.., TD(-2), 
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TD(-l), pictures of said old sequence are decoded, while, in the meantime, the buffer fullness 

increases according to the bitrate R(OLD) (the value of VBR(OLD) indicates at what time the 

first bit to be decoded has been stored, after transmission, in the decoder's buffer). The line L(NS) 

similarly corresponds to the state of the buffer fullness for the new sequence alone : at times 

5 TD(0), TD(1), TD(2), and so on, pictures of said new sequence are decoded, while, in the 

meantime, the buffer fullness increases according to the bitrate R(NEW) (simila-ly, the value of 

VBV(NEW) indicates at what time the first bit to be decoded has been stored in the decoder's 

buffer). The line L(SWO) corresponds to the real state of the buffer when switching is performed 

and before the decoded data corresponding to the new sequence enter the 

10 buffer : the decrease of the fullness at decoding times is the same as previously for the old 

sequence, but no further decoded data enter the buffer. The line L(SWN) corresponds to the real 
state of the buffer if the decoded data corresponding to the new sequence enter said buffer : there 

f,* is an overflow, at time TD(-l) in this example. 

}:=; The proposed method solves this problem, as can be seen in Fig.4. As 

few? 

*tis previously in Fig.3, the line L(0S) corresponds to the state of the buffer fullness for the old 

fin 

Ly sequence, without any modification. The line L(SWO) originally corresponds to the state of the 
|jf buffer when switching is performed, the modification according to the invention beginning at the 
switching time, when an additional minimal pjcture AMP is inserted at rate R(OLD) after the old 

-13 

f'U sequence. This minimal picture allows to delay by one period T(V) the storing step of the new 
! |o sequence (the whole line L(NS) is only delayed by one period T(V), for one additional minimal 
picture) and also the (instantaneous) decoding time of this new sequence, which is in the present 
case sufficient to prevent buffer overflow. This delay is indeed sufficient to allow the decoder's 
buffer fullness to decrease enough to avoid the overflow occurring in Fig.3. Obviously, more 
minimal pictures may be introduced, only their minimal number k being evaluated as indicated 
25 above. 

The whole switching method in accordance with the invention may therefore 
be implemented as illustrated in Fig. 5 and according to the following steps, initialized at the 
position "START" : 

(1) is a switch requested ? to this question, illustrated by : SW ?, the reply is : 
30 (a) no : the procedure is re-initialized ; 

(b) yes : the value of k is initialized to 0 (k = 0), and the second step can be 

carried out ; 
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(2) is an I or P picture detected in the old sequence ? to this question, illustrated by 

: OLD : I or P ?, the reply is : 

(c) no : a loop allows to wait until an I or P picture is really present and 

detected ; 

(d) yes : the transmission of the old sequence is stopped (illustrated by 
STOP-OLD), i.e. no further bits enter the decoder's buffer while the decoding step continues, and 
the third step can be carried out ; 

(3) is an I picture ready in the new sequence ? to this question, illustrated by : 
NEW : I ?, the reply is : 

(e) no : k is increased by one (k = k+1), a minimal picture is transmitted at 
rate R(OLD) and the fourth step can be carried out ; 

(f) yes : the fourth step can be directly carried 

out ; 

(4) is VB V(NEW) greater than VBV(OLD) + k.T(V) ? to this question, illustrated 
by VB V ?, the reply is : 

(g) yes : the number k* of minimal pictures to be inserted is computed 
(illustrated by : COMP k'), and the fifth step can be carried out ; 

(h) no : the fifth step can be directly carried out ; 

(5) is R(NEW) greater than R(OLD) ? to this question illustrated by : 
R(NEW)/R(OLD), the reply is : 

(i) yes : the number k M such as possible overflow is avoided is computed 
(illustrated by : COMP k M ), and the sixth and seventh steps can be carried out ; 

(j) no : the sixth and seventh steps can be directly carried out ; 

(6) the value of k is increased according to the formula : k = k + max(k', k"), and k 
minimal pictures are transmitted at rate R(OLD) ; 

(7) the transmission of the new sequence begins (illustrated by TRANS-NEW), at 
a time t such as t = TD(NEW)-VBV(NEW), i.e. t = TD(OLD) + k.T(V) - VBV(NEW). 

It is then clear that, at the first switching point, before TS(OLD), the 
decoder's buffer does not underflow nor overflow since the old video sequence is a compliant 
compressed video sequence (i.e. the decoder's buffer fullness is strictly ensured by the encoding 
process). Between TS(OLD) and TD(OLD), the decoder's buffer does not underflow, since there 
are always bits of pictures to decode in the buffer (either pictures of the old video sequence or UC 
pictures), nor overflow since bits of UC pictures enter with a rate lower than or equal to R(OLD), 
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which is the bitrate of a compliant compressed video sequence. Between TD(OLD) and 

TD(NEW), the decoder's buffer does not underflow, since there are always bits of pictures to 

decode in the buffer (either UC pictures or pictures of the new video sequence) nor overflow, 

since UC pictures are so short (when considering the number of bits) that the buffer fullness is 

lower than the fullness at TD(NEW), which is itself a fullness associated to a compliant 

compressed video sequence. After TD(NE W), the decoder's buffer obviously does not underflow 

or overflow since the new video sequence is a compliant compressed video sequence. 

The present invention is obviously not limited to the case of a single video 

switching. For instance, the case of a video sequence replacement (as presented in the beginning 

of the description) is equivalent to perform switching two times : a first time, when the old 

sequence is replaced by minimal pictures and said minimal pictures are replaced by the second 

sequence, and a second time, when the second sequence is replaced by minimal pictures and said 

minimal pictures are replaced by the original old sequence. In such a situation, the minimum 

number of minimal pictures to be inserted the second time must be chosen so that the first old 

picture to be again transmitted is an I picture, which implies that this second number of minimal 

pictures is not fixed but dependent of the GOP structure. It is known, also, that a GOP may be 

organized in the following manner : 

- BO, Bl, 12, B3, B4, P5, B6, B7, P8,..., .... in the display order ; 

- 12, BO, Bl, P5, B3, B4, P8, B6, B7,..., ... in the transmission order. 

Due to B pictures definition, it is clear that pictures BO and Bl are coded by using prediction from 
12 and from the last P picture of the previous GOP, which defines a so-called non closed GOP. To 
solve the problem raised by the fact that first B pictures, at transitions, will be decoded by using 
prediction from a P picture of a completely different sequence, first B pictures of such non closed 
GOPs will be replaced by minimal pictures at transitions. In this case, these minimal pictures are 
bidirectional predictive-coded pictures in which only the first and last macroblocks of each slice 
are encoded with only forward prediction, null forward vectors and no error prediction (the other 
macroblocks are said skipped macroblocks). Thus a decoder will consider such minimal pictures 
as copies of the last presented I or P picture. 

This solution is also illustrated in Fig. 5, in which corresponding additional 

steps are provided : 

(8) is the first GOP of the new sequence a closed GOP ? to this question, 
illustrated by : GOP ?, the reply is : 
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(k) yes : the implementation of the method according to the invention is 

completed ("END") ; 

(1) no : the ninth step can be carried out ; 

(9) is a picture detected in new sequence after the first I picture ? to this question, 
5 illustrated by : PICTURE ?, the reply is : 

(m) no : a loop allows to wait until a picture is really present and detected ; 
(n) yes : the tenth step can be carried out ; 

(10) is said detected picture a B picture ? to this question, illustrated by : B 
PICTURE ?, the reply is : 

10 (o) yes : said B picture is replaced by a B minimal picture BMP ; 

(p) no : the implementation of the method is completed ("END"). 
Obviously, the invention is not limited to the above-described method, and it 

V & also relates to a device for implementing said switching method and to a decoding system 

Q 

p including such a device. A system for decoding at least two and preferably n parallel video 

1$ bitstreams corresponding to video sequences of pictures of type T - I, P or B is described for 

W instance in the Euro-PCT patent application 0783817 (PHF95003). Such a system, shown in 

W: Fig. 6, comprises a demultiplexer 60 which receives an input bitstream IB including a plurality 

.jU (generally n, only two in the represented embodiment) of individual video bitstreams and the 

| y outputs of which (two in the case of Fig.6) are sent to storing means 70 comprising in this 

J* 

}£p embodiment the same number (two) of buffers (71 and 72). 

The switching action occurs in a control unit 81 provided for selecting the 
buffer corresponding to the selected bitstream which will be decoded, for instance the buffer 72, 
and, at the same time, for controlling the transfer of the other bitstream (which at that moment 
has not to be decoded, since it has not been selected, for instance by an user action) towards the 
25 other buffer 71. At the outputs of parallel buffers 71 and 72, a switch 82 controlled by the control 
unit 81 with which it constitutes control means 80 selects the appropriate buffer output signal and 
sends it towards a decoder 90. This decoder comprises for example a demultiplexer 91 (provided 
for separating the signals to be decoded and associated motion vectors), a variable length decoder 
92, a dequantizer 93, an inverse orthogonal transform circuit 94, and a prediction circuit 
30 comprising a memory 95, a motion compensation circuit 96 (receiving said motion vectors), and 
an adder 97 which yields the output decoded signals DS to be displayed (such a decoder is 
conventional and will not be described in a more detailed manner). The present invention relates 
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'both to a switching device such as the one constituted by said control means and to a decoding 

system comprising such a switching device. 



